<template>
  <div class="comSelect-container">
    <custom-tree-select :options="treeData" v-model="innerValue" :placeholder="placeholder" clearable
      :disabled="disabled" v-on="$listeners" lastLevel>
    </custom-tree-select>
  </div>
</template>

<script>
export default {
  name: 'dicSelect',
  props: ["value", "disabled", "placeholder"],
  model: {
    prop: 'value',
    event: 'input'
  },
  data () {
    return {
      treeData: [],
      innerValue: this.value
    }
  },
  methods: {
    async getData () {
      this.treeData = await this.$store.dispatch('generator/getDicTree')
    }
  },
  created () {
    this.getData()
  },
  watch: {
    innerValue (val) {
      val && this.$emit('change', val)
    },
    value (val) {
      this.innerValue = val
    }
  }
}
</script>
<style lang="scss">
.comSelect-container {
  .el-select {
    width: 100%;
  }
}
</style>